草庐IT

TypeScript 基础类型

全部标签

javascript - 为什么在确定类型相等时使用 ===?

似乎尽可能首选严格相等运算符-我将我的代码放在JSLint中并获得了以下反馈。代码:functionlog(){console.log(arguments.length==1?arguments[0]:arguments);}来自JSLint的反馈:Problematline2character34:Expected'==='andinsteadsaw'=='.我很想知道===比==有什么优势。基本上,.length返回一个Number,1也是一个Number。你可以100%确定,所以===只是一个多余的额外标记。此外,在您知道类型始终相同的情况下检查类型也没有性能优势。那么这里使用=

javascript - jasmine-node 是否提供任何类型的 "fail fast"选项?

当我从命令行运行一套jasmine测试时,我想要某种类型的快速失败选项,以便它在第一个断言错误时停止今天有这样的东西吗? 最佳答案 刚拼在一起jasmine-bail-fast获得这种行为。npminstalljasmine-bail-fast然后在你的第一个规范之前:require('jasmine-bail-fast');jasmine.getEnv().bailFast();希望得到它mergedtojasminecore然后作为标志添加到jasmine-node。 关于javas

javascript - 如何在整个 Web 应用程序堆栈中利用 Haskell 类型安全?

我想知道以CRUD为中心的Web应用程序可以从Haskell的类型系统中获益多少,尤其是当前端是使用JavascriptMVC框架(如AngularJS传递无类型数据对象)构建时。在我看来,一旦将Haskell数据类型转换为JSON对象,并将其传递给繁重的JavaScriptMVC框架层,将Haskell的类型系统作为Web堆栈的一部分的好处就会开始急剧下降,因为没有让类型检查器确保通过整个Web应用程序的数据流的类型完整性的方法。例如,您可以更改数据库模式和关联的Haskell类型,但类型检查器无法告诉您JavaScriptMVC前端的哪些部分也需要更新。我认为这是一个问题。我是否正

javascript - TypeScript 和 Html2Canvas?

有谁知道Html2Canvas库是否有可用的TypeScript定义文件(d.ts)?Html2Canvas是一个很棒的库,可以使用JavaScript截取浏览器的屏幕截图。参见https://github.com/niklasvh/html2canvas了解更多详情。 最佳答案 从1.0.0-rc.2版本开始,类型被添加到npm中的html2canvas包中。所以如果你安装它使用npmihtml2canvas@1.0.0-rc.2或者安装更高版本,你可以使用html2canvaswithtypescript。

javascript - 使用 Typescript 延迟加载模式

因此,对于C#和其他具有属性获取和设置评估程序的语言,构建延迟加载模式非常简单。我最近才开始使用TypeScript,并且我正在尝试实现相同的目标。我正在通过Ajax调用加载具有大部分属性的Poco。问题可以描述如下:exportinterfaceIDeferredObject{HasLoaded:boolean;DeferredURI:string;}exportclassLibrary{LibraryName:string;Books:IDeferredObject;}exportclassBook{Title:string;UniqueNumber:number;}window.

javascript - Angular 过滤器 + typescript

我有一个非常简单的Angular过滤器。这个过滤器接受一个枚举成员的输入(这里称为XEnum)并返回代表枚举成员的字符串:moduleFilters{"usestrict";exportfunctionXEnumToStringFilter(){return(input:XEnum)=>{returnXEnum[input];}}}[...]moduleModel{exportenumXEnum{Started=0,Stopped=1}}[...]app.filter("xEnumToStringFilter",[Filters.XEnumToStringFilter]);当我在我的V

javascript - Function.prototype.call 在严格模式之外改变 this 的类型;为什么?

varexample=function(){console.log(typeofthis);returnthis;};在严格模式下:example.call('test')#prints'string'否则,example.call('test')#prints'object'然而,console.log(example.call('test'))版画test(如你所料)为什么Function.call更改typeof'test'==='string'绑定(bind)到this里面example? 最佳答案 当使用call()并将t

javascript - 从 react 组件的数组类型状态属性中弹出的正确方法?

假设我有一个像这样的react组件:varMyComponent=React.createClass({getInitialState:function(){return{myStack:[]};},...pop:function(a){//anyconcise,elegantwaytopopfromarraytypestate?}}也许我可以写pop:function(){varclone=_.clone(this.state.myStack);clone.pop();this.setState({myStack:clone});}但它看起来很丑...我知道它可以工作,但是当我编写这

javascript - 使用 ES6 模块的 TypeScript 的最佳方法是什么?

我正在开始一个新的Web项目并尝试使用TypeScript,主要作为ES6转译器,但也有类型检查的额外好处,特别是对于现有的库,例如jQuery结合了DefinitelyTyped类型定义。从最新版本开始,TypeScript既支持自己的内部模块,也支持ES6模块,后者称为“外部”模块。因为ES6比TypeScript更标准,所以我打算使用ES6/外部模块而不是传统/内部TypeScript模块。我在多个文件/模块中定义了自己的代码,但我希望构建生成一个我可以从浏览器加载的.js文件。问题是,据我所知,TypeScript在使用自己的模块格式时只能生成单个输出文件。如果我尝试使用ES6

javascript - typescript + react : defining defaultProps correctly

假设您这样定义组件:interfaceIProps{req:string;defaulted:string;}classCompextendsReact.Component{staticdefaultProps={defaulted:'test',};render(){const{defaulted}=this.props;return({defaulted.toUpperCase()});}}当你想使用它时,TypeScript需要你的defaultedprop,即使它是在defaultProps中定义的://ERROR:TypeScript:prop'defaulted'isreq